From a85a31246a56e513597a3edc0de33d32856bdeed Mon Sep 17 00:00:00 2001 From: Keir Fraser Date: Mon, 10 Jan 2011 08:42:32 +0000 Subject: [PATCH] x86-64: don't allow wrmsr to MSR_FAM10H_MMIO_CONF_BASE when Xen itself is using it Signed-off-by: Jan Beulich --- xen/arch/x86/traps.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/xen/arch/x86/traps.c b/xen/arch/x86/traps.c index f7d8f69c9c..6e2c5c7311 100644 --- a/xen/arch/x86/traps.c +++ b/xen/arch/x86/traps.c @@ -1694,6 +1694,10 @@ static int is_cpufreq_controller(struct domain *d) (d->domain_id == 0)); } +#ifdef CONFIG_X86_64 +#include "x86_64/mmconfig.h" +#endif + static int emulate_privileged_op(struct cpu_user_regs *regs) { struct vcpu *v = current; @@ -2288,7 +2292,14 @@ static int emulate_privileged_op(struct cpu_user_regs *regs) goto fail; if ( !IS_PRIV(v->domain) ) break; - if ( (rdmsr_safe(MSR_FAM10H_MMIO_CONF_BASE, val) != 0) || + if ( (rdmsr_safe(MSR_FAM10H_MMIO_CONF_BASE, val) != 0) ) + goto fail; + if ( +#ifdef CONFIG_X86_64 + (pci_probe & PCI_PROBE_MMCONF) && + (pci_probe & PCI_CHECK_ENABLE_AMD_MMCONF) ? + val != msr_content : +#endif ((val ^ msr_content) & ~( FAM10H_MMIO_CONF_ENABLE | (FAM10H_MMIO_CONF_BUSRANGE_MASK << -- 2.30.2